<script setup>
import {onMounted, ref} from 'vue';
import luckysheet from "luckysheet";
import LuckyExcel from 'luckyexcel'
import {processTableData, transformData} from "@/utils/method";
import AnalyesAPI from "@/api/system/analyes";
import {useAnalysetStore} from "@/store/index";
import {getUserInfo} from "@/utils/auth";
import dayjs from "dayjs";
import CapacityB from "@/components/analysisSheetComponents/ambientAir/tmpl81/index.vue";
import Index from '@/components/analysisSheetComponents/component/index.vue'
import Device from "@/components/analysisSheetComponents/component/Device.vue";

let options = {
  container: "luckysheet", //luckysheet为容器id
  lang: 'zh',
  autoCalculate: true,
  data: [
    {
      "column": 10, // 列数
      "row": 10, // 列数
      "defaultRowHeight": 30, // 自定义行高
      "defaultColWidth": 100, // 自定义列宽
      "celldata": [
        // 初始化表格数据，第一行包含表头
        {"r": 0, "c": 0, "v": "样品编号",}, // A1
        {"r": 0, "c": 1, "v": "类型",}, // A1
        {"r": 0, "c": 2, "v": "_____体积Vn(L)",}, // B1
        {"r": 0, "c": 3, "v": "含氧量φ´(O₂)(%)",}, // B1
        {"r": 0, "c": 4, "v": "试样总体积V（mL）",}, // B1
        {"r": 0, "c": 5, "v": "稀释倍数f",}, // B1
        {"r": 0, "c": 6, "v": "滤筒;滤膜;吸收瓶;ρ₁(mg /L)",}, // B1
        {"r": 0, "c": 7, "v": "吸收瓶ρ₂(mg/L)",}, // B1
        {"r": 0, "c": 8, "v": "监测浓度c₁(mg/m³)",}, // B1
        {"r": 0, "c": 9, "v": "测定结果",}, // B1
        {"r": 0, "c": 10, "v": "排放浓度C₂(mg/m³)",}, // B1
        {"r": 0, "c": 11, "v": "备注",}, // B1
      ], // 初始化数据
      "config": {
        "merge": {}, // 合并单元格
        "columnlen": { // 设置列宽
          "0": 130, // 第一列宽度 150px
          "1": 130, // 第二列宽度 120px
          "2": 130, // 第三列宽度 180px
          "3": 130, // 第四列宽度 100px
          "4": 130, // 第五列宽度 200px
          "5": 130,  // 第六列宽度 150px
          "6": 130,  // 第六列宽度 150px
          "7": 130,  // 第六列宽度 150px
          "8": 130,  // 第六列宽度 150px
          "9": 130,  // 第六列宽度 150px
        }, // 表格列宽
      },
    }
  ],
  showinfobar: false, // 隐藏信息栏
  showtoolbar: true, // 隐藏工具栏
};
const tableOption = ref([
  {table: '仪器名称', id: 1,}
])
const waterForm = ref({
  bdatas: {
    bzqxhz: {},
    qxjhdcd: Array.from({length: 9}, () => ({
      ypbh: '',
      cdjg: '',
      xdwc: '',
      zkyq: '',
      sfhg: '',
    })),

  },
  kbycd: Array.from({length: 7}, () => ({
    ypbh: '',
    ypnd: '',
    zkyq: '',
    sfhg: '',
  })),
  bzycd: Array.from({length: 5}, () => ({
    byph: '',
    cdnd: '',
    bzz: '',
    sfhg: '',
  })),
  unit: {},
    // 复制粘贴
  device: {
  device_name: [],
  device_model: [],
  device_number: [],
  }
})
const analyseStatusPage = useAnalysetStore()
const record_sn = analyseStatusPage.waterForm.record_sn
const processedData = ref([])
const cdatas = ref([])
const checkDialogVisible = ref(false)
const checkTime = ref('')
const userInfo = JSON.parse(getUserInfo())
const switchAB = ref(true)
const sheetData = ref('')
const jsonData = ref(null)
const switchAdd = ref(true)
// 在组件挂载后初始化 Luckysheet

onMounted(() => {
  // 初始化表格
  luckysheet.create(options);
  // 获取初始数据并保存在响应式变量中
  sheetData.value = options.data
  // 获取表单信息
  getWaterCapacity()
  // 复制粘贴
  getMethod()
});

// 获取工作表信息
const getWaterCapacity = () => {
  let josn = {
    add_form_id: analyseStatusPage.waterForm.add_form_id,
    task_id: analyseStatusPage.waterForm.taskId,
    // id: 25,
    record_sn: record_sn,
    // record_sn: 40,
  }
  AnalyesAPI.getAnalyseACapacity(josn).then(data => {
    console.log('获取水质容量 A单', data)
      // 复制粘贴
      if (!Array.isArray(data) || data.length !== 0) {
      waterForm.value = data
      sheetData.value = data.configs
      options.data = sheetData.value
      luckysheet.create(options);
      processedData.value = data.adatas
    } else {
      waterForm.value.device = {
        device_name: [],
        device_model: [],
        device_number: [],
      }
    }
  })
}
// 获取信息( 复制粘贴)
const getMethod = () => {
  waterForm.value.task_name = analyseStatusPage.waterForm.task_number //任务名称
  waterForm.value.method = analyseStatusPage.waterForm.tableItem.test_method
      ? analyseStatusPage.waterForm.tableItem.test_method
      : analyseStatusPage.waterForm.tableItem.test_method_number;//分析方法
  waterForm.value.category_id = analyseStatusPage.waterForm.tableItem.sample_category // 样品类别
  checkTime.value = analyseStatusPage.waterForm.tableItemList.submit_dates
}

const handleAddWaterPh = () => {
  sheetData.value = luckysheet.getLuckysheetfile();
  options.data = sheetData.value; // 将字符串解析为 JSON
  console.log(options.data)
  const data = options.data[0].data.map(row => {
    return row
        .map(cell => {
          return cell ? {
            field: cell.m || "默认字段",
            value: cell.v || null
          } : null;
        })
        .filter(cell => cell !== null); // 删除 null 值
  });
  console.log(data);
  // 调用函数
  processedData.value = processTableData(data);
  cdatas.value = transformData(processedData.value)
  console.log('processedData.value', processedData.value)
  console.log(cdatas.value)
  if (waterForm.value.check_status !== undefined) {
    delete waterForm.value.check_status
    delete waterForm.value.reviewer_id
  }
  //   调接口拿数据
  AnalyesAPI.addWaterCapacity({
    ...waterForm.value,
    // record_sn: record_sn,
    record_sn: 81,
    // id: analyseStatusPage.waterForm.id,
    task_id: analyseStatusPage.waterForm.taskId,
    configs: sheetData.value,
    add_form_id: analyseStatusPage.waterForm.add_form_id,
    adatas: processedData.value,
    cdatas: cdatas.value,
  }).then(data => {
    console.log('调接口拿数据', data)
    ElMessage.success('保存成功！')
    switchAdd.value = false
  })
};


// 用于获取最新的表格数据
const getUpdatedData = () => {
  checkDialogVisible.value = true
};
const handleCheckClose = () => {
  checkDialogVisible.value = false
}

// 确认提交
const handleSubmit = () => {
  console.log(checkTime.value)
  const formattedDate = checkTime.value ? dayjs(checkTime.value).format('YYYY-MM-DD') : '';
  console.log(formattedDate); // "2025-02-06"
  console.log(analyseStatusPage.waterForm.id)
  AnalyesAPI.handleCheckTimeData({
    id: analyseStatusPage.waterForm.add_form_id,
    submit_date: formattedDate
  }).then(data => {
    if (data === 1) {
      ElMessage.success('提交成功！')
      checkDialogVisible.value = false
    }
  })
}

// 上传文件
const loadExcel = (evt) => {
  const files = evt.target.files
  console.log(files)
  if (files == null || files.length == 0) {
    alert('No files wait for import')
    return
  }
  let name = files[0].name
  let suffixArr = name.split('.'),
      suffix = suffixArr[suffixArr.length - 1]
  if (suffix != 'xlsx') {
    alert('Currently only supports the import of xlsx files')
    return
  }
  LuckyExcel.transformExcelToLucky(files[0], function (exportJson, luckysheetfile) {
    if (exportJson.sheets == null || exportJson.sheets.length == 0) {
      alert('Failed to read the content of the excel file, currently does not support xls files!')
      return
    }
    console.log('exportJson', exportJson.sheets)
    jsonData.value = exportJson

    luckysheet.destroy()
    luckysheet.create({
      container: 'luckysheet', //luckysheet is the container id
      showinfobar: false,
      data: exportJson.sheets,
      title: exportJson.info.name,
      userInfo: exportJson.info.name.creator
    })
  })
}

const handleSwitch = () => {
  switchAB.value = !switchAB.value
}
</script>

<template>
  <div class="card">
    <div v-show="switchAB">
      <el-card class="box-card">
        <h1 style="text-align: center">环境空气和废气 离子色谱法分析原始记录（A面）</h1>
        <div>SXLPHJ/JL/CX-22-81</div>
        <table class="table">
          <tr style="background-color: #f2f2f2">
            <td colspan="2">任务编号</td>
            <td colspan="2">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.task_name"/>
            </td>
            <td>采样日期</td>
            <td colspan="2">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.sampling_time"/>
            </td>
            <td colspan="1">分析日期</td>
            <td colspan="4">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.anal_time"/>
            </td>
          </tr>
          <tr>
            <td colspan="2">分析方法</td>
            <td colspan="10">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.method"/>
            </td>
          </tr>
          <tr style="background-color: #f2f2f2">
            <td colspan="2">测试项目</td>
            <td colspan="2">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.fxxm"/>
            </td>
            <td>检出限</td>
            <td colspan="2">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.limit_val"/>
            </td>
            <td colspan="1">样品类别</td>
            <td colspan="4">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.category_id"/>
            </td>
          </tr>
          <Device :water-form="waterForm"></Device>
          <tr style="background-color: #f2f2f2">
            <td colspan="2">测定条件</td>
            <td colspan="10">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.cdtj"/>
            </td>
          </tr>
          <tr>
            <td colspan="2" rowspan="2">计算公式</td>
            <td colspan="4" rowspan="2">
              <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.js_formula"/>
            </td>
            <td colspan="1">环境条件</td>
            <td colspan="5">
              <div>
                <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                          v-model="waterForm.temperature">
                  <template #append>
                    <span style="background-color: transparent;color: black">℃</span>
                  </template>
                </el-input>
                <el-input style="width: 100%;border: 1px solid transparent" placeholder="请输入"
                          v-model="waterForm.humidity">
                  <template #append>
                    <span style="background-color: transparent;color: black">%RH</span>
                  </template>
                </el-input>
              </div>
            </td>
          </tr>
          <tr>
            <td colspan="1">基准含氧量φ(O₂) (%)</td>
            <td colspan="5">
              <el-input style="width: 200px;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.jzyhl"/>
            </td>
          </tr>
          <tr style="background-color: #f2f2f2">
            <td colspan="2">备注</td>
            <td colspan="10">
              <el-input style="width: 200px;border: 1px solid transparent" placeholder="请输入"
                        v-model="waterForm.notes"/>
            </td>

          </tr>
        </table>
        <!--      <input id="uploadBtn" type="file" @change="loadExcel"/>-->
        <div id="luckysheet" style="width:100%;height:500px;"></div>
      </el-card>
    </div>
    <div v-show="!switchAB">
      <capacity-b :water-form="waterForm"></capacity-b>
    </div>
  <!--    底部公共按钮 (复制粘贴)-->
  <div>
      <Index :water-form="waterForm" :handle-add-water-ph="handleAddWaterPh" :check-time="checkTime" :switch="true" :switch-a-b="switchAB" :handle-switch="handleSwitch"
             :get-water-capacity="getWaterCapacity" :switch-add="switchAdd"></Index>
    </div>
  
  </div>

</template>

<style scoped>
.card {
  padding: 20px 25px;
}

.table {
  width: 100%;
  border-collapse: collapse;
  /* 表格边框合并 */
  text-align: left;
  /* 默认左对齐 */
  font-size: 14px;
  /* 字体大小 */
  color: #606266;
  /* 默认字体颜色 */
  margin-bottom: 20px;
}

.table th,
.table td {
  border: 1px solid #c2bfbf;
  /* 表格单元格边框颜色 */
  padding: 12px;
  /* 单元格内边距 */
}

.table th {
  background: #f5f7fa;
  /* 表头背景色 */
  font-weight: 600;
  /* 表头字体加粗 */
  color: #303133;
  /* 表头字体颜色 */
  text-align: center;
  /* 表头居中 */
}

.table td {
  width: 15%;
}

.table-td {
  display: flex;
}

::v-deep .el-input__wrapper {
  background-color: transparent;
  box-shadow: none;
}

::v-deep .el-select__wrapper {
  background-color: transparent;
  box-shadow: none;
}

::v-deep .el-input-group__append {
  background-color: transparent;
  box-shadow: none;
}
</style>
